package com.yizhuoyan.his.dao;

import com.yizhuoyan.his.entity.HosDepartmentEntity;
import com.yizhuoyan.his.qco.DepartmentQueryQco;

import java.util.List;
import java.util.Map;

/**
 * (HosDepartment)表数据库访问层
 *
 * @author yizhuoyan@yizhuoyan.com
 * @since 2020-02-20 15:06:13
 */
public interface HosDepartmentDao extends TemplateDao<Long,HosDepartmentEntity>{

    //额外方法

    /**
     * 通过科室类别查询科室
     * @param categoryId 科室类别id
     * @return 科室集合
     * @throws Exception
     */
    List<HosDepartmentEntity> selectByCategoryId(long categoryId)throws Exception;

    /**
     * 通过名称查询科室
     * @param name 需要查询的条件 科室名称
     * @return 科室集合
     * @throws Exception
     */
    List<HosDepartmentEntity> selectByName(String name)throws Exception;

    /**
     * 通过 科室编码查询科室
     * @param code 需要查询的条件 科室编码
     * @return 科室集合
     * @throws Exception
     */
    List<HosDepartmentEntity> selectByCode(String code)throws Exception;

    /**
     *  通过科室分类id查科室
     * @param typeConstantId 科室分类id
     * @return 科室集合
     * @throws Exception
     */
    List<HosDepartmentEntity> selectByTypeConstantId(long typeConstantId)throws Exception;
    /**
     * 根据需求查询科室
     * @param qco 需要查询的选项
     * @return 返回科室集合
     * @throws Exception
     */
    List<HosDepartmentEntity> selectByDemands(DepartmentQueryQco qco)throws Exception;
}